- 
                Notifications
    You must be signed in to change notification settings 
- Fork 1.8k
          Refactor FormatArgsExpn
          #9349
        
          New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
  
    Refactor FormatArgsExpn
  
  #9349
              
            Conversation
| Maybe this makes #8857 unnecessary? | 
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
This all is really specific to how the format_arg! macro expands. But that also was the previous code, so I don't see this as a blocker.
However, I noticed that the pattern is to construct those things from rpf information. Can you give an estimation how likely it is to add this information to rpf and give Clippy access to it? This feels like we're doing work that is/can already (be) done in rustc.
Those are no blockers. Just a few comments how the code could maybe be improved.
17bc0ef    to
    88600bf      
    Compare
  
    There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Only 2 minor comments, then we can move on with the other PR 🚀
| 
 I don't think  There is talk of making  | 
80cbf42    to
    cd8eda5      
    Compare
  
    cd8eda5    to
    4f049f5      
    Compare
  
    There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Thanks, just another detail. After that r=me.
| @bors r+ Thanks! | 
| ☀️ Test successful - checks-action_dev_test, checks-action_remark_test, checks-action_test | 
It now for each format argument
{..}has:Exprit points to, and how it does so (named/named inline/numbered/implicit)FormatSpec(format trait/fill/align/etc., the precision/width and any value they point to)The caller no longer needs to pair up arguments to their value, or separately interpret the
specsExprs when it isn'tNoneThe gist is that it combines the result of
rustc_parse_format::Parserwith the macro expansion itselfThis unfortunately makes the code a bit longer, however we need to use both as neither have all the information we're after.
rustc_parse_formatdoesn't have the information to resolve named arguments to their values. The macro expansion doesn't contain whether the positions are implicit/numbered/named, or the spans for format argumentsWanted by #9233 and #8518 to be able to port the changes from #9040
Also fixes #8643, previously the format args seem to have been paired up with the wrong values somehow
changelog: [
format_in_format_args]: Fix false positive due to misattributed argumentsr? @flip1995
cc @nyurik